import './public-path';
import Vue from 'vue'
import App from './App.vue'
import './plugins/element.js'
import router from './router'
import store from './store'
import commonComponents from "@/components/common";

Vue.config.productionTip = false



let vm = null 

function render(props={}){
  console.log(props);
  const { container } = props;

  Vue.prototype.$rootRouter = props.data.router

   // 子应用组件向父应用注册回调
  props.data.callback({components: commonComponents})

  console.log( commonComponents );

  vm = new Vue({
    router,
    store,
    render: h => h(App)
  }).$mount(container ? container.querySelector('#app') : '#app');


  
}

// 独立运行时
if (!window.__POWERED_BY_QIANKUN__) {
  render();
}

/**
 * bootstrap 只会在微应用初始化的时候调用一次，下次微应用重新进入时会直接调用 mount 钩子，不会再重复触发 bootstrap。
 * 通常我们可以在这里做一些全局变量的初始化，比如不会在 unmount 阶段被销毁的应用级别的缓存等。
 */
export async function bootstrap() {
  console.log('[vue] vue app bootstraped');
}

/**
 * 应用每次进入都会调用 mount 方法，通常我们在这里触发应用的渲染方法
 */
export async function mount(props) {
  console.log('[vue] props from main framework', props);
  render(props)
}
/**
 * 应用每次 切出/卸载 会调用的方法，通常在这里我们会卸载微应用的应用实例
 */
export async function unmount() {
  vm.$destroy()
  vm.$el.innerHtml = ''
  vm = null
}

// 手动调用钩子
export async function update(props) {
  console.log('update props', props);
}